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and a pluratify of the CRC bits, for example 
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address fitter further includes programmable 
control circuitry (U1, U2. US) for indicating that 
the received address equals the target address 
If (a) the CAM has an entry that equals all or a 
potion of the received address and/or if (b) the 
CRC of the received address is recognized by 
the Hash fitter. The address filter also includes 
circuitry (28) for correcting the hash function, if 
required, for bits that arrive before the (n) ad- 
dress bits. 
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FIELD OF THE INVENTION: 

This invention relates generally to data communication apparatus and method and, In particular, to appa- 
ratus and method enabling a local area network (LAN) station to efficiently recognize a received LAN address. 

BACKGROUND OF THE INVENTION: 

The subject matter of the following publications is incorporated by reference herein: American National 
Standard for Information Systems, Fiber Distributed Data Interface (FDD!) - Token Ring Media Access Control 
(MAC) ANSI X3. 139-1987; IEEE Standards for Local and Metropolitan Area Networks: Overview and Archi- 
tecture, Std 802-1990: A Primer to FDD!: Fiber Distributed Data Interface, copyright 1991, Digital Equipment 
Corporation. 

Reference is made to the following definitions. 

Statton: An addressable logical and physical attachment in a ring, capable of transmitting, receiving, and 
repeating Information. 

Ring: Two or more stations connected by a physical medium wherein information is passed sequentially 
between active stations, each station in turn examining or copying and repeating the information, finally re- 
turning the information to the originating station. 

Media Access Control (MAC): A Data Link Layer responsible for the scheduling of data transmissions to 
and for receiving transmissions from a shared medium Local Area Network (e.g., an FDDI ring ). 

Token: A unique symbol sb-eam that indicates the right to transmit on a shared medium. On a Token Ring, 
the Token circulates sequentially through the stations in the ring. At any time, it may be held by no stations or 
by one station. 

Frame: A Protocol Data Unit (PDU) bxinsmitted between cooperating MAC entities on a ring, including a 
starting delimiter, addresses, a variable number of data octets (eight ordered bits that form a pair of data syn>- 
bols), and an ending delimiter. 

Protocol Data Unit (PDU): A unit of data transfer between communicating peer layer entities which may 
contain control, address and data information. FDDI MAC PDUs are Tokens and Frames. 

Receive: The action of a station in accepting a Token, Frame, or other symbol sequence from the incoming 
medium. 

Transmit: The action of a station In generating a Token, Frame, or other symbol sequence and placing it 
on the outgoing medium. 

Addresses: A set of 48-bit station addresses, which may be a station's unique address, a 48-bit Broadcast 
Address (all ones), and any other 48-bit Group Addresses recognized by a station. 

Fig. 1 is an exemplary embodiment of a specific network topology. It should be realized that the teaching 
of the invention also applies to a number of other network topologies, including Carrier Sense Multiple Ac- 
cess/Collision Detect (CSMA/CD) networks. 

As seen in Fig. 1 a token ring 1 Includes a set of stations 2 (designated A-N) that are serially connected 
by a transmission medium 3, such as an optical fiber, to form a closed loop. Information is transmitted sequen- 
tially, as a stream of bits, from one active station 2 to the next. Each station 2 generally regenerates and repeats 
each bit and serves as a means for attaching one or more devices to the ring for the purpose of communicating 
with other devices on the ring. A given station that has access to the medium 3 transmits Information onto the 
ring, where the information circulates from one station to the next The format of the circulating information 
includes a destination address, a source address, and a data field. In the IEEE 802 format, the first bit of the 
destination address specifies whether the destination address is an individual address or a group (multicast) 
address. That is, whether the destination address specifies the LAN address of a specific station or, in the case 
of a group address, the stations to which the associated data field is directed. An addressed destination station 
or stations copies the information as it passes. Eventually, the station that originally b^nsmitted the information 
removes the information from the ring 1. 

Each LAN address, as specified by the IEEE 802 standard, consists of 48 bits. Of these, the first, or most 
significant, 24 bits identify the organizatkin owning the address. For example, all group addresses assigned 
to a given organization begin with the same 24 bits that uniquely Identify the organization. These first 24 bits 
are referred to as an "Organizationally Unique Identifier" (OUI). In general, in any given LAN the number of 
OUIs is small. The remaining 24 bits, for an individual address, uniquely identify each of the stations for that 
organization that are coupled to the LAN. 

On a token ring a Frame typically also includes a Frame Status field that contains an E-indicator, A-indicator 
and C-indicator. The E-lndicator is used to indicate if the Frame has been detected to contain an error. The A- 
indicator is used to indicate if the destination address of the Frame has been matched by one or more stations 
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2 on the ring. The C-indicator is used to indicate if the Frame was received and copied by one or more stations 
2 on the ring. 

Each station 2 contains a Destination Address list The Destination Address iist contains a set of addresses 
that the station uses to compare with the Destination Address of each received Frame. If a match is found then 

5 the Frame is received and copied. On a tol<en ring, if a match is found the station receives and copies the Frame 
and, in addition, sets the A-indicator and C-indicator when repeating the Frame. The Destination Address list 
contains the station's My Address and one or more Alias Addresses. An "alias address" Is an address different 
from the station's individual address but used in a similar manner as the individual address. For example, an 
application may require that an alias address be used as a source address when transmitting Frames. Also the 

10 "alias address' may be used to compare with the destination address field of a Frame when receiving Frames. 
A typical implementation of one of the stations 2 may have two individual addresses and 32 group address- 
es In the Destination Address list 

A problem arises as communication networks become larger and fester, and as addresses associated with 
stations increase in size. That Is, a need has arisen to optimize a station address comparison function. 

15 In general, datalink adapters coupled to a LAN are required to recognize destination addresses associated 
with Frames conveyed by the LAN. Many conventional network adapters have only one individual address, 
which may be easily recognized. However, in that each network station may also accept a number of group 
addresses, the adapter is also required to quickly determine whether to receive the group Frame. For example, 
for some token ring networks, e.g., FDDI, receiving stations are required to set an "Address Recognized" flag 

20 in the received Frame. For the smallest size Frames this implies that the address must be recognized within 
11 octets, or 0.88 microseconds. This requirement places an upper bound on the time within which end stations 
must recognize group addresses. For example, bridges, which are used to interconnect two or more LANs, must 
recognize the destination addresses of every Frame and rapidly decide whether to receive the Frame for for- 
warding. Also, routers in wide area networks (WAN) typically must examine a large forwarding database to de- 

25 cide the output link for a given destination address. 

Several high-speed networks simplify the problem of address lookup by using a hierarchical address for- 
mat that allows the forwarding path to be looked up directly. Although this approach results in fast routing, the 
association of a destination's unique identifier (generally a 48-bit Individual address) to the corresponding hi- 
erarchical address at the originating statk>n still requires searching through a large address database. 

30 One method to determine whether to accept the Frame of data is to employ a hardware lookup of the ad- 
dress In a list or a table of acceptable addresses. This is the approach taken in Content Addressable Memories 
(CAMs). One significant advantage of a CAM is that there Is provided perfect address recognition. That is, given 
a network address the CAM determines with certainty whether the address is within a table of acceptable ad- 
dresses. However, CAMs are highly gate-intensive and add significant complexity, power consumption, and 

35 consume a significant amount of surface area when implemented within an integrated circuit Furthermore, 
the CAM search time increases as the number of addresses which must be recognized increases. With a trend 
towards a client-server form of distributed computing, the number of group addresses that a given station must 
receive is continuously increasing. As such, the practical limits of the CAM-approach to address recognition is 
quickly reached. 

40 Another address recognition method employs a hash filter to map the received address into a bit mask. 
Hashing is generally performed in two steps. In the first step, an address A is converted to a hash value f(A). 
In the second step, some m bits of f(A) are extracted so that a total number of hash cells is 2'". The logic state 
of a predetermined bit in the mask indicates whether a given received address is to be accepted or rejected. 
One significant advantage of the hash approach is that the speed of hashing is independent of the number of 

45 addresses and is thus particularly suitable if the number of acceptable addresses Is large. However, a disad- 
vantage of hashing is that if the size of the bit mask is made small, so as to reduce the required circuib-y, several 
addresses may map to the same bit. Thus, the hashing approach provides imperfect filtering of the received 
addresses. 

In many LANs, the destination address is the first part of the Frame, and the Frame Is passed through a 
so cyclic redundancy check (CRC) circuit As a result it has been recognized that the bits of the CRC provide a 
mechanism for hashing. In that each network station may have a number of group addresses that are to be 
received by the station, the network adapter employs the CRC polynomial as a hash function to reject Frames 
associated with undesired group addresses. 

In one hashing approach, described in a device specification entitled "MK68590 Local Area Network Con- 
55 troiier for Ethernet" (United Technologies Mostek), a group address filter includes a 84 bit mask composed of 
four sixteen bit registers used to accept incoming group addresses. This is an imperfect filter that requires a 
host processor to perform final filtering. The first bit of the incoming address must be a "1" for either the Logical 
Address Filter or the Broadcast Address decode to be enabled. Otherwise the incoming address is an individual 
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address and is compared against tlie contents of a 48 bit register. 

Ali incoming data passes through a CRC Generator. In the case of a group address, the six most significant 
bits of the CRC Generator are strobed into the Hash Register after the 48th bit of the group address has passed 
through the CRC Generator. The six bits select one of the 64 bits in the Logical Address Filter such that Hash 
Address 00 selects bit 0 and Hash Address 63 selects bit 63. If the selected mask bit is a "1", the address is 
accepted. However, different organlzattons can assign group addresses which may map to the same bit of the 
hash mask, resulting in a collision. 

What is not taught by the prior art, and what is thus an object of this invention to provide, is a network ad- 
dress recognition method and apparatus that combines the use of a CAM and a Hash filter, in conjunction with 
a careful allocation of group addresses, to provide perfect address recognition while minimizing a required 
amount of circuitry and complexity. 

The apparatus and method of the invention described herein provide improved flexibility In assigning group 
addresses. 

SUMMARY OF THE INVENTION 

The foregoing and other problems are overcome by a method and apparahjs for comparing a first value 
to a second value to determine if the first value equals the second value. The invention in its broad form resides 
in a method, for a network having a destination address comparator, of comparing a first value comprised of 
(n) bits to a second value to determine if the first value equals the second value, said method comprising the 
steps of: comparing a portion of the first value, the portion being comprised of (n - x) bits, to one or more values 
stored within a memory means for determining if the memory means has a stored value that corresponds to 
the portion of the second value; filtering the first value with a hash filter means for determining if the first value 
is recognized by the hash filter means; and declaring that the first value equals the second value only if it is 
determined that (a) the memory means has a stored value that equals the portion of the first value and that 
(b) the first value is recognized by the hash filter means. 

Preferably, the first value is represented by (n) address bits received from a communication network, such 
as a Token ring LAN. 

As described herein, an address comparator includes circuitry for storing the received address and for ap- 
plying all or a portion of the stored address to a CAM containing entries storing one or more target addresses. 
The address comparator also Includes a Hash filter for filtering the first value for determining if the first value 
is recognized by a Hash mask. The receh/ed address is applied to a hash function generator, such as a CRC 
generator, and a plurality of the resultant bits, for example nine, are used to access the Hash mask. The address 
comparator further includes a programmable control circuitry for indicating that the received address equals 
the target address if (a) the CAM has an entry that equals all or a portion (GUI) of the received address and/or 
if (b) the bits from the hash function generator, resulting from the received address, are recognized by the Hash 
filter. In a presently preferred embodiment of the invention the hash function generator Includes a CRC gen- 
erator. A technique is also disclosed for correcting the CRC for bits that arrive before the destination address. 

BRIEF DESCRIPTION OF THE DRAWING 

A more detailed understanding of the inventton may be had from the following description of a preferred 
embodiment, given by way of example and to be understood in conjuction with the accompanying drawing 
wherein: 

Fig. 1 schematically depicts a token ring network; 

Fig. 2a is a simplified block diagram showing the combined CAM/Hash filter used to recognize network 
addresses; 

Fig. 2b is a block diagram showing in greater detail the CRC Correction block of Fig. 2a; and 

Figs. 3 and 4 illustrate address storage formats for a 4B bit address and for two Organizationally Unique 

Identifiers, respectively. 

DETAILED DESCRIPTION OF THE INVENTION 

The ensuing description of a preferred embodiment of the invention is made in the context of a FDDI token 
ring data communications network that conforms to the ANSI and IEEE 802 standard. It should be realized, 
however, that the teaching of the Invention is applicable to other networks and standards, such as CSMA/CD, 
OSI, and TCP/IP networks. In general, the teaching of the invention is applicable to any network that operates 
In accordance with IEEE 802 address fbrmats, including, by example, IEEE 802.3, IEEE 802.5, etc.. 
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In this regard reference is made to the foilowing documents: ANSI/IEEE Std. 802.3-1985, 'Carrier Sense 
Multiple Access with Collision Detection (CSMA/CD) Access Method and Physical Layer Specifications', Insth 
tute of Electrical and Electronic Engineers; ANSI/IEEE Std. 802.5-1989, Token Ring Access Method and Phys- 
ical l^yer Specifications", Institute of Electrical and Electronic Engineers; Postel, J., Ed. Internet Protocol 
Specification", SRI International, Menio Park, CA. Sept 1981 RFC-791; Postel, J., Ed. Transmission Control 
Protocol Specification", SRI International, Menio Park, CA, Sept 1981, RFC-793; and Information Processing 
Systems - Open Systems Interconnection (OS!) - Basic Reference Model, International Organization for Stan- 
dardization, Oct 1984, Draft International Standard 7498. 

Furthermore, and as will be made apparent below, it should be realized that the teaching of the invention 
applies In general to the decoding of information that is expressed in a digital format 

In recognition of the fact that there are generally but a few OUIs associated with a given LAN, and referring 
to block diagram of Fig. 2a, the invention employs an address filter 10 having a CAM 12 that recognizes the 
OUI portion of the LAN address. The CAM 12 thus confirms whether a specific network address has been as- 
signed to an organization associated with the statton 2 that includes the address filter 10. In parallel with ttie 
operation of the CAM 12, the invention employs a hash filter 14. This combination of CAM lookup and hash 
filtering results in perfect filtering of network addresses, provided that the addresses are assigned such tiiat 
collisions cannot occur. That is, perfect filtering is achieved so long as no more than one address hashes to 
any given bit in a hash mask 16. Alternately, given a set of addresses, the teaching of the invention enables 
the selection of a hash function that eliminates or minimizes the occurrence of hashing collisions. 

By careful address allocation perfect filtering can be achieved. Careful address allocation entails selecting 
an address, hashing the selected address, and determining If a collision occurs. If collision occurs another ad- 
dress is selected and the process repeated. 

It should be noted that in Fig. 2a a signal line designated USER INPUT is coupled to a plurality of circuit 
blocks. This signal line indicates a data path through which a user programs values into certain of ttie logic 
blocks, as will be described. 

The incoming bit stream from the LAN 1 is routed in parallel to. an address register 20, that includes serially 
connected registers 20a, 20b, and 20c, and to CRC logic 22. 

A bit counter 18 Is connected to a bit dock and is enabled to count the bit docks by a "start of frame' signal. 
The counter 1 8 is used to give an indication of the arrival of the last bit of the destination address. For example, 
in FDDI the counter 18 counts the bit docks until it reaches a count of 58. This indicates a condition wherein 
56 bits have been received from the LAN 1 . The first eight bits of the Frame, which indicate Frame control In- 
formation, are stored in an eight bit Frame control register 20d that has an input serially coupled to an output 
of address register 20c. The next 48 bits, indicating the destination address fbr ttie Frame, are stored in the 
address registers 20a-20c. The first bit of the 48 bits is stored in the 1-bit register 20c and indicates whetiier 
ttie address is an individual or a group address. This bit is referred to as an l/G bit The remaining 47 address 
bits are stored in address registere 20a and 20b. 

The CAM 12 indudes a plurality of entries, for example four, only one of which is shown in Fig. 2a. The 
CAM entry is comprised of three registers: a 24 bit CAM enb-y 24a, a 23 bit CAM entry 24b, and a one bit CAM 
entry 24c. Each register of the CAM entry has an output coupled to an input of an associated comparator 26a, 
26b, and 26c. The other comparator input is coupled to the assodated 24 bit, 23 bit or one bit address register 
20a-20c, respectively. 

There are two output signal lines from the CAM 12. Depending upon the state of mode control registers 
associated with the CAM entries, the first output (x) indicates whether ttie received address matches the first 
24 bits, the OUI address portion, of any CAM entry. The second output (y) indicates whether the address match- 
es all 4B bits of any CAM entry. 

Specifically, ttie (x) output is sourced from a gate 12a having as inputs the output of bit counter 18 and ttie 
outputs of comparatora 26b and 26c. Gate 1 2a asserts an enabling output when, after tiie reception of 56 bits, 
ttie f iret 24 bits of the CAM entry equal the 24 bits of ttie address stored in address registers 20b and 20c. The 
output (y) is sourced from a gate 12b having as inputs ttie output of gate 12a and comparator 26a. The output 
of gate 12b is asserted when, after the receptnn of 56 bits, the firet 24 bits of the CAM entry equal the 24 bits 
of ttie address stored in address registere 20b and 20c, as indicated by the output of gate 12a, and also ttie 
24 bits of CAM entry 24a equal the 24 bits in address register 20a. 

As was previously stated, only one CAM entry is shown in Fig. 2a. Typically, each of the plurality of CAM 
entries indudes 48 bits of CAM entry 24a-24c, associated comparatore 26a-26c and decoding gates. The mode 
control registere U1, U2 and U3 are associated modes for the matching CAM enti-y. After the destination ad- 
dress has been received fully the destination address is compared to all of the CAM entries in parallel so as 
to determine if one of the plurality of CAM entries matches the received address. 

Further in accordance with the invention a hashing function generator Is supplied to operate upon the re- 
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ceived bit stream. In a presently preferred embodiment of the invention the hashing function generator is a CRC 
generator, although the teaching of the invention is not limited to only the use of a CRC technique. For example, 
the hash function generator may employ specific bits of the destination address, a correlation of address bits, 
checksums, or XOR folding. A description of these various techniques is made in a technical report entitled *A 
Comparison of Hashing Schemes for Address Lookup in Computer Networks", DEC-TR-593, by R. Jain (1989), 
which is available from the Digital Equipment Corporation, Littleton, MA 01460. 

The CRC logic 22 performs a 32-bit Cyclic Redundancy Check (CRC) of the first 56 bits. By removing the 
effect of the first eight bits, that is, the Frame control field stored in register 20d, the CRC for the destination 
address Is obtained. Only the first few bits of the CRC, for example nine bits, are used in hashing. The effect 
of the Frame control field is removed by CRC correction logic 28. Provided with the Frame control field from 
register 20d the CRC correction logic 28 determines the quantity to be exclusive-ored with the output of the 
CRC logic 22 to obtain only the CRC for the received address. The corrected nine bits of CRC are used as an 
index into a hash mask which, in a presently preferred embodiment of the invention, is a 512-bit hash mask 
16 comprised of, by example only, 32 16-bit registers HM00-HM31. 

For embodiments of the Invention not having a Frame control field before the destination address no cor- 
rection of the hashing function may be required. Furthermore, for embodiments of the invention that employ 
other than a CRC technique, and that require hash function cornBction, the correction mechanism is selected 
in accordance with the hash function. 

As seen in Fig. 2b the CRC correction logic 28 includes, in a presently preferred embodiment of the in- 
vention, a read only memory (ROM) 28a that stores a set of nine (ROM locations 0-8) n-bit numbers, wherein 
n equals the number of bits of CRC that are used to index the 2" hash mask 16. ROM 28a has address inputs 
coupled to the frame control register 20d. The CRC correction logic 28 also includes an n-bit correction register 
28b which is initialized with the contents of the 0th ROM location. In operation, the content of the ith ROM 28a 
location is exdusive-or'ed with logic 28c to the correction register 28b if and only if the ith bit in the frame control 
register 20d is set. This operation may occur as the frame-type bits are received from the LAN and well before 
the final bit of the destination address is received. After the last bit of the destination address has been received 
the content of the correction register 28c and the CRC register 22a are exdusive-or'ed through logic 28d to 
produce the n-bit index into the hash mask 16. 

In accordance with a preferred embodiment of the Invention a set of nine 32-bit correction values, ex- 
pressed in hexadecimal notation, is as follows: 



0 BB-7E-75-34 

1 2D-D0-EE-65 

2 94-88-F9-E9 

3 C8-24-F2-2F 

4 E6-72-F7-CC 

5 73-39-7B-E6 

6 39-9C-BD-F3 

7 9E-AE-D0-22 

8 I4F-57-68-II 

Only those bits that are used to form the index into the hash mask need to be stored In the ROM 28a. For 
example, for a nine-bit Implementation the ROM 28a contains the fbllowing: 
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ROM 28a Location 



Content 

10111011-0 

00101101-1 

10010100-1 

11001000-0 

11100110-0 

01110011-0 

00111001-1 

10011110-1 

01001111-0 



These are the first nine bits of the 32-blt correction vaiues shown previously and are obtained by evaluating 
the expression: 

modIx(M- i).g(x)]. 

by setting i=1, 2, 8, where the cyclic redundancy check polynomial is g(x). 

The content of the 0th ROM 28a location Is 

modi (x» + x-w) l(x), g(x)]. 

In this expression l(x) is a polynomial of degree 31 with all coefficients equal to one. 

As an example, the received frame control is 01010000, which is a Logical Link Control (LLC) firame of pri- 
ority 0 (lowest asynchronous priority). The firame control information is stored within the frame control register 
20d. 

After the frame control is received, the computation of the correction factor is begun. In that the second 
and fourth bits in the frame control are set, ROM locations 0, 2, and 4 are exdusive-or'ed as follows. 



10111011-0 
10010100-1 
UlOOllQ-Q 
11001001-1 



It will be remembered that the correction register 28b was initialized to the content of ROM 28a location 
zero. The result is stored In correction register 2Bb. 

After 56 bits of the frame are received (i.e., the last bit of the destination address), the CRO register 22a 
contains: 



10 10 1110-0101 1100-1011 1000-000001 10 



Employing logic 28d to exduslve-or the first 9-bits of the CRC register 22a with the correction factor stored 
in correction register 28b there is obtained: 



10101110-0 
UQOlOQl-l 
result 01100111-1 
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The 9-bit index Into the hash mask 16 is thus 1-11100110, or 486. 

If an B-bit index is desired instead of a 9-bit index, it is preferred to use bits 2 through 9 (rather than bits 
1 through 9). The 8-bit index using these bits wouid be 1-1110011, or 243. 

Having thus described a presently preferred embodiment of the CRC correction logic 28, the discussion 
5 of the remainder of Fig. 2a will now be continued. 

The user specifies acceptable address match patterns by programming, for each CAM entry, the associ- 
ated mode control registers U1 , U2 and U3. This programming is accomplished in accordance with the following 
Table. 



Ul U2 U3 

Hash-mask 

control Resulting mode 

Y Accept all Frames 
having Hash mask 
comparison only 

N All Frames having OUI 

match are accepted 

Y All Frames having OUI 
match *and* Hash are 
accepted 

N Full 48-bit match 

(Normal CAM Mode) 

Y Full 4 8-bit match 
*or* Hash mask 
comparison 

N Full 48-bit match 

*or* OUI match 

Y Full 48-bit *or* 
(OUI Match *and* 
Hash mask match) 

N None 

A Decision Logic Block 32 includes gates connected as shown and decodes the output of Counter 18, the 
outputs A and B of the CAIV1 1 2, the outputs of mode registers Ul , U2, and U3, and the output of the Hash Mask 
16 so as to provide a signal designated ADDRESS MATCH OUTPUT ADDRESS MATCH OUTPUT is asserted 

BO if the received address is accepted, otherwise ADDRESS MATCH OUTPUT Is deasserted. Other circuitry, not 
shown, receives the ADDRESS MATCH OUTPUT signal and performs further MAC functions. 

It should be noted that 48-bit or GUI-match user choices are per-CAM entry choices, whereas the hash 
match choice applies globally to all CAM entries. For example, a usermay specify two OUI's: one to be accepted 
unconditionally while the other is to be accepted only if the corresponding hash-bit is also set. 

ss Another mode of use employs a plurality of the hash masks 16, with the user specifying a specific hash 
mask number for use with each CAM 12 OUI. For this embodiment, and by example, four 128-bit hash masks 
are provided. A first CAM entry is associated with a first hash mask, a second CAM entry is associated with 
a second hash mask etc. An OUI match with a particular one of the CAM entries selects the corresponding 

8 
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hash mask to be used for the hash filter. The dashed line shown In Fig. 2a indicates a hash mask select Input 
from the CAM 12. 

Although the hash technique may used for both individual and group addresses, it is most effective if used 
only for group addresses. This is because the group address assignments may be readily controlled to avoid 
5 all hash collisions, while individual address assignments are not normally as readily controlled. The output sig- 
nal line from the 1-bit register, the l/G bit, is depicted to show a preference that the hash mask be used only 
for group addresses. This signal line is not required if individual addresses are also to be recognized using the 
hash mask. 

In summary, an embodiment of the invention Includes for each of a plurality, for example four, of addresses 
10 (ADDRESS 1-ADDRESS 4), a set of mode control registers (U1-U3), a set of address registers (20a-20c), and 
a set of CAM entry registers 24a-24c and associated supporting circuitry, including the comparators 26a-26c. 
The hashing function for all address entries is accomplished with the CRC logic 22, the CRC correction logic 
28, and the Hash mask 1 6. The address size used is 48 bits, which includes the 24 bit GUI. Filtering of addresses 
is accomplished with a 512 bit hash function indexed by nine bits of the corrected CRC. 
15 A feature of the invention Is the use of a 48-bit CAM entry to store two 24-bit OUIs, referred to herein as 
QUI A and QUI B. The CAM 12 register format for QUI A and QUI B are shown in Fig. 4, where Word #1, bit 
#0 is the l/G bit for QUI A. and where Word #2, bit M is the l/G bit for QUI B. It should be noted that other than 
16-bit words may be employed. 

Each of the Mode Control Registers (U1-U3 for each CAM enfry) provides the ability to select one of the 
20 following modes: 

1. Disable; 

2. Enable Perfect Address; 

3. Enable QUI and Hash; or 

4. Enable GUI only. 

25 If the selection is Enable QUI and Hash, or is Enable GUI only, then the following conditions are possible: 

1. GUI A is Valid; 

2. GUI B Is Valid; 

3. GUI A and GUI B are Valid. 

That is, each of the CAM 12 address registers 20a-20c contains the following information for each of a 
30 plurality of separate cases. 



CASE 


MODE CONTROL 
REGISTER 


ADDRESS REGISTER 


1. 


Disable 


don't care 


2. 


Enable Perfect Address 


Contains a 48 bit address 


3. 


Enable OUI and Hash 


Contains up to two GUI's (OUI A and B) 


4. 


Enable OUI Only 


Contains up to two GUI's '(GUI A and B) 



The CAM 12 register format for the 48 bit address is shown in Fig. 3, where a 48 bit address is shown as 
three 16-bit words. Word #1 , bit #0 is the l/G (Individual/Group) bit which is the first bit of the address that is 
transmitted and received. Word #3, bit 15 is the last address bit transmitted and received. Bit order for b^ns- 
mit/receive is Word #1 , bit #0 to bit #1 5, Word #2, bit #0 to bit #15, and Word #3, bit m to bit #1 5. 

An exemplary set-up mode for a Frame receive operation is as follows. 



50 
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STEP 


ACTION 


1. 


Address register 1 is written with address X1. 


2. 


Address register 2 is written with address X2. 


3. 


Address register 3 is written with OUI Y1 and OUI Y2. 


4. 


Address register 4 is written with OUI Y3 as OUI A. 


5. 


The Hash Function is written to the Hash mask 16 with Z (512 bits). 


6. 


Mode Control Register 1 is written with Enable Perfect Address. 


7. 


Mode Control Register 2 is written with Enable Perfect Address. 


8. 


Mode Control Register 3 is written with Enable OUI and Hash, OUI A is Valid, and OUI B is Valid. 


9. 


Mode Control Register 4 is written with Enable OUI Only, and OUI A is Valid. 



The programming of the mode registers as set forth above enables the station 2 to recognize ttie following 
Frames. 

1 . Frames with a destination address equal to XI or X2. 

2. Frames with OUI Y3 or OUI Y2 and with a hash function matching Z. 

3. Frames with the OUI Y3. 

As was stated previously, a number of possible address hashing approaches may be employed in the prac- 
tice of the invention, including hashing using checksums and hashing using XOR folding. An analysis of the 
several contending address hashing techniques in the aforementioned technk^ report entitled "A Comparison 
of Hashing Schemes for Address Lookup in Computer Networks", DEC-TR-593, by R. Jain (1989), shows that 
the CRC of the address provides an excellent hashing function. This approach is summarized below. 

Given a 48 bit address {ao, a,, at a47}, the 32-bit CRC of the address can be computed by forming the 

fbilowing polynomial: 



and computing the remainder when the polynomial (a(x))x^ is divided by the following CRC polynomial (as em- 
ployed in IEEE 802 protocols): 



The coefficient of the remainder polynomial is used as the hashing function. It should be noted in Equation 
(1) that the first 32 bits of the address are complemented. Although the algebraic description of CRC compu- 
tation, as presented above, appeare complex, the hardware implementation of the technique through the use 
of shift registere Is straightforward. 

The size of the hash mask 16 required to obtain a desired level of performance is a function of several 
competing factors. For example, it is assumed that the hash filter includes a simple M x 1 bit mask, that is, 
each hash mask cell is one bit wide. A hash function is used to map the LAN 1 address to an index value I in 
the range 0 through M-1. If the ith bit in the hash mask 16 is set, the Frame is accepted for further processing; 
otherwise, the Frame is rejected. Such a hash filter is a perfect rejection filter in the sense that if the mask bit 
is zero, it is determined with certainty that the LAN address is not wanted. On the other hand, the hash filter 
is an imperfect acceptance filter In the sense that when the mask bit Is one, there is some probability that the 
LAN address is not one of those wanted by the station. This is because more than one LAN address can hash 
to the same mask location. 

In accordance with an aspect of the invention (n) bits from the LAN address CRC are employed as an index 
into a 2" bit hash mask 16 and provides a collision-free hash filter 14. In general, it has been determined that 
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a 2" bit mask is suitabie for use with an organization that assigns one-tenth as many [2" /10] local LAN ad- 
dresses. Thus, for eight bits of LAN address CRC the resulting hash table is 2^, or 256 bits, in length, for nine 
bits of LAN address CRC the resulting hash table is 2*, or 512 bits, in length. In the presently preferred enrv 
bodiment of the invention the hash mask is embodied within the 32 16-bit registers (HMOO - HM31). 

5 The combined CAM and hash filter 10 enables significant savings in circuitry, complexity and power con- 

sumption. As an example, for recognizing 32 group addresses assigned to a user, a 512 bit hash mask using 
nine bits of CRC was found to provide a collision-free hash filter. This hash mask, combined with three 24-bit 
one entry CAMs, was sufficient to perfectly recognize ail user-assigned group addresses at an organization. 
However, a 32 entry (48 bite per entry) CAM would require, at a minimum, (32 X 48) or 1536 bits of storage, 

10 including numerous associated comparators. 

The teaching of the invention is not intended to be construed to be limited to the specific embodiment dis- 
closed herein. For example, addresses having more or less than 48 bits may be recognized, more or less than 
four CAM 12 entries may be employed, registers may be organized to have more or less than 16-bits, and the 
hash mask may comprise more or less than 512 bits. Furthermore, the functionality of the address filter 10 

15 may be realized with discrate circuits, a single integrated circuit, a programmed data processor, or a combin- 
ation of such components. Also, the teaching of the invention is not restricted for use with any one particular 
network embodiment. For example, the invention may also be used with non-token ring networks such as IEEE 
802.3 and IEEE 802.4. 

Thus, while the invention has been particularly shown and described with respect to a preferred embodi- 
20 ment thereof, it will be understood by those skilled in the art that changes in form and details may be made 
therein without departing firom the scope and spirit of the invention. 



Claims 

25 

1. In a network having a destination address comparator, a method of comparing a first value comprised of 
(n) bits to a second value to determine if the first value equals the second value, said method comprising 
the steps of: 

comparing a portion of the first value, the portion being comprised of (n - x) bits, to one or more 
30 values stored within a memory means for determining if the memory means has a stored value that cor- 
responds to the portion of the second value; 

filtering the first value with a hash filter means for determining if the first value is recognized by 
the hash filter means; and 

declaring that the first value equals the second value only if it is determined that (a) the memory 
35 means has a stored value that equals the portion of the first value and that (b) the first value is recognized 

by the hash filter means. 

2. A method as set forth in claim 1 wherein the step of filtering includes the steps of: 

determining a hash function value of the first value; and 
40 applying (m) bits of the hash function value to the hash filter means. 

3. A method as set forth in Claim 1 wherein the memory means is a content addressable memory means 
and wherein the method includes an initial step of storing at least one entry within the content addressable 
memory means the stored entry being equal to the portion of the second value. 

^ 4. A method as set forth in Claim 1 and including an initial step of receiving the first value from a communi- 
cation network means, wherein the first value represents a communication network address, and wherein 
the portion of the first value represents an organizationally unique identifier (OUI) portion of the commu- 
nicatton network address. 

^ 5. A method as set forth in Claim 5 wherein (n) equals 48 and wherein (x) equals 24. 

6. A method as set forth in claim 1 wherein the hash filter means is comprised of a plurality of hash filters 
and wherein the step of filtering includes a step of selecting one of the hash filters as a function of the 
portion of the first value. 

55 

7. A method as set forth in Claim 2 wherein the step of determining a hash function value includes a step of 
determining a CRC value of the first value. 

11 
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8. A method as set forth in Claim 7 wherein (m) is equal to or less than 32. 

9. A method as set forth in Claim 1 wherein the steps of comparing and filtering are accomplished in parallel. 

10. In a communication network which handles destination addresses, apparatus for comparing a first value 
of an address to a second value to determine if the first value equals the second value, the first value 
being received from a communication network and including (n) address bits, comprising: 

means, having an input coupled to the communication network, for comparing a portion of the first 
value to one or more values stored within a menury means for determing if the memory means has a 
stored value that corresponds to the portion of the second value, the portion being comprised of (n - x) 
bits, where x Is equal to or greater than zero; 

filtering and determining means, having an input coupled to the communication network, forf iltering 
the first value with a hash filter means for determining if the first value is recognized by the hash filter 
means; and 

having inputs coupled to an output of the comparing means and to an output of the hash filter means, 
for determining that the first value equals the second value if (a) the memory means has a stored value 
that is equal to the portion of the first value and/or if (b) the first value is recognized by the has filter means. 

11. Apparatus as set forth in Claim 10 wherein the filtering and determining means includes: 

means for determining a hash function value of the first value; and 

means for applying (m) bits of the hash function value to the hash filter means. 

12. Apparatus as set forth in Claim 1 0 wherein the memory means is a content addressable memory means 
having at least one entry for storing a value equal to the portion of the second value, wherein the portion 
of the first value represents an organizationally unique identifier (OUI) portion of a communication network 
address 

13. Apparatus as set forth in claim 12 wherein (n) equals 48 and wherein (x) equals 24. 

14. Apparatus as set forth in Claim 11 wherein said hash function value determining means includes means 
for generating a cyclic redundancy check (CRC) of the first value. 

15. Apparatus as set forth in Claim 11 wherein (m) is equal to or less than 32. 

16. Apparatus as set forth in Claim 14 wherein the network address Includes 48 bits (ao, ai, a2 a47}, and 

wherein the CRC value of the network address is determined by forming the polynomial: 




and wherein a remainder of the polynomial (a(x))x^2 is determined by dividing the polynomial by: 



17. Apparatus as set forth in Claim 12 wherein the at least one entry is partitioned into three fields, a first 
field having 24 bits, a second field having 23 bits, and a third field having one bit, and wherein the third 
field stores an address bit that indicates if the address is an individual address or a group address. 

18. Apparatus as set forth in Claim 11 wherein said applying means includes means for correcting the deter- 
mined hash function value for any bits that precede the (n) address bits. 

19. Apparatus for recognizing an address received from a communication network, comprisisng: 

means for storing the received address; 
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content addressable memory means having entries for storing one or more target addresses; 

means for comparing at least a portion of tlie stored received address to the one or more stored 
target addresses, the comparing means having an output for indicating if a match occurs between the stor- 
ed received address and one of the stored target addresses; 

means for storing a hash masl( comprised of a plurality of bits, a predetermined one or ones of the 
bits being set to correspond to one or more target addresses, the hash masl< storing means having an 
Input and further having an output for Indicating the state of a bit selected by the input; 

means for generating a cyclical redundancy check (CRC) value corresponding to the received ad- 
dress, a portion of the CRC value being applied to the input of the hash mask storing means; and 

control means for selecting the output of the comparing means and/or the output of the hash mask 
storing means for indicating if the stored received address equals a target address. 

20. A method of filtering addresses received from a communication network by a network station to determine 
if a received address identifies the network station, comprising the steps of: 

applying an address received from the communication network to a CAM having at least one entry 
to determine if the CAM has a matching address stored within the at least one entry; 

filtering the network address with a hash Filter means for determining if a hash mask has a bit set 
that corresponds to the network address; and 

determining if the address Identifies the network station in accordance with one of the following 
criteria: 

(a) only if the hash mask has a bit set that corresponds to the network address; 

(b) only If an organizationally unique Identifier (GUI) portton of the received network address is deter- 
mined to equal a 

(c) only if the GUI portion of the received network address is determined to equal a CAM entry, and if 
the hash mask has a bit set that corresponds to the network address; 

(d) only if the network address, including the GUI portion, is determined to equal a CAM entry; 

(e) only if the network address, including the GUI portion, is determined to equal a CAM entry, or if the 
hash mask has a bit set that corresponds to the network address; 

(f) only if the network address. Including the GUI portion, is determined to equal a CAM entry, or if the 
GUI portion of the received network address is determined to equal a CAM entry; and 

(g) only if the network address, including the GUI portion, is determined to equal a CAM entry, or it the 
GUI portion of the received network address is determined to equal a CAM entry and If the hash mask 
also has a bit set that corresponds to the network address. 
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